package com.ruoyi.system.domain;

import com.ruoyi.common.annotation.Excel;
import com.ruoyi.common.annotation.Excel.ColumnType;
import com.ruoyi.common.core.domain.BaseEntity;
import jakarta.persistence.*;
import jakarta.validation.constraints.NotBlank;
import jakarta.validation.constraints.Size;
import lombok.Data;
import lombok.EqualsAndHashCode;
import org.apache.commons.lang3.builder.ToStringBuilder;
import org.apache.commons.lang3.builder.ToStringStyle;
import org.hibernate.annotations.DynamicInsert;
import org.hibernate.annotations.DynamicUpdate;

import java.io.Serial;

/**
 * 参数配置表 sys_config
 *
 * @author ruoyi
 */
@EqualsAndHashCode(callSuper = true)
@Entity
@DynamicUpdate
@DynamicInsert
@Data
public class SysConfig extends BaseEntity {
	@Serial
	private static final long serialVersionUID = 1L;

	/** 参数主键 */
	@Excel(name = "参数主键", cellType = ColumnType.NUMERIC)
	@Id
	@GeneratedValue(strategy = GenerationType.AUTO, generator = "sys_config_seq")
	@SequenceGenerator(name = "sys_config_seq", initialValue = 1000)
	private Long configId;

	/** 参数名称 */
	@Excel(name = "参数名称")
	@NotBlank(message = "参数名称不能为空")
	@Size(max = 100, message = "参数名称不能超过100个字符")
	private String configName;

	/** 参数键名 */
	@Excel(name = "参数键名")
	@NotBlank(message = "参数键名长度不能为空")
	@Size(max = 100, message = "参数键名长度不能超过100个字符")
	private String configKey;

	/** 参数键值 */
	@Excel(name = "参数键值")
	@NotBlank(message = "参数键值不能为空")
	@Size(max = 500, message = "参数键值长度不能超过500个字符")
	private String configValue;

	/** 系统内置（Y是 N否） */
	@Excel(name = "系统内置", readConverterExp = "Y=是,N=否")
	private String configType;

	@Override
	public String toString() {
		return new ToStringBuilder(this, ToStringStyle.MULTI_LINE_STYLE)
				.append("configId", getConfigId())
				.append("configName", getConfigName())
				.append("configKey", getConfigKey())
				.append("configValue", getConfigValue())
				.append("configType", getConfigType())
				.append("createBy", getCreateBy())
				.append("createTime", getCreateTime())
				.append("updateBy", getUpdateBy())
				.append("updateTime", getUpdateTime())
				.append("remark", getRemark())
				.toString();
	}
}
